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Abstract of WO0250664 

In an emulated computing environment, a method is provided for logically decoupling the host operating 
system from the processor system with respect to certain processor settings of the processor. A 
hypervisor of the emulation program replaces some of the processor settings of the processor with 
processor settings associated with software routines or data structures provided by the guest operating 
system; The replaced processor settings are written to memory. During this period, when the processor 
calls a software routine or accesses a data structure associated with the replaced processor setting, the 
processor will call or access a software routine or access a data structure associated with the guest 
operating system, bypassing the host operating system and communicating directly with the guest 
operating system. When the host operating system is to be recoupled to the processor, the processor 
settings that have been saved to memory are rewritten to the appropriate registers of the processor. 
During the period that the hypervisor is coupled to the processor, the page table of the hypervisor is 
established such that it largely mirrors the page table of the guest operating system. If a change to the 
page table of the guest operating system causes a conflict between the page table of the guest operating 
system and the page table of the hypervisor, the page table of the hypervisor is reallocated in a manner 
that is transparent to the guest operating system. 
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77-^f 7f-tit'llfit5x5al/-3'7'ni*'7i,i!) ( , fX h^Xfa-^^XfA 
^^©^-^U-i/ 3 >^^fy§ 0 l5al'-^7D^7Att 1 tvXFv^VCA-F 1 )! 30 

?f ti, i;al/-FJft5SlrtT'lttt5V7 h 7x7K tfi^S 
ft§ifr^i:©IW© J *>9i:D©«fil£llfct. 
[ 0 0 0 7 ] 

m ^ - /% << if a , * x h * ^ u - f - -c >^->xfioA-**H;nois< ic n ft -f s 

f&J Sf 7 D ^ ^ A "J? <K *XFt^l/-f -f y^v-XfAKnol :3$fctt«S©2&* 
^Iz-f^^i'XTAi 1 , 3yifa-?->XfA©7Dt7*^ttJ3y t?a-^ i'X 

f i 1 ©A-K')i7?ffifflt'f §i^»ilft5o ^i/-r-fyy>'XfA(?)A-f^-/i 

-< If « , 2**^l/-7 0y'>Xf AC*^l/-7-fV^M5lSil/-Ft5, * 
© US JR , H Hi K tt 8U © ^ - K -7 x 7 *5 <fc XS / £ fc « * * U - r w > ^ -> X f A 30S1 S£ F*3 T Wi 
ft t T ^ 5 "J ^ tt & 9 s *Xh*^l/-fO^->Xf Alin^ta-^i'XrAOi 40 

aiw»rt-efc3W&ttff**«£fc, 2*t^i/-f^y->x7Atf ( ^otc/\-H 

■)i7feitf/Jf:IU^l/-f ^>^->Xf ASIrtt*lttLTfe!)3>lfa-^->X 
^AOttJllWIHIrtK&SfcfiUSo ^<Ct^l/-rO^>'XfAIJ 1 * - f -f > 

y -> x t a # * fc *> 3i > tr x - * x r a cd m - k f x 7 © mm w n a snj si k fe 5 

©*5teflfl*L*tttitf*&ft^ £$©*^U-r^ y^->XfA*'» 

X r A © / W - /W If «: , ^n^ncD^^b-r-f y y'>Xf itfftftfrta >K j- 
^^XxA^^tC^TcoT^MttWSJ^^WtS^cDJcotC^ftl-rScfc^tC, ftil©*^ b- 

[ 0 0 0 8 ] 50 
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A©^*'J%$tf, * 7. h ny ifa-? ->^f F 7 x 7 £ a I® K f'J ffl 1* £ c 

>y*/7f AO*J8TtfeD, a - "9* l" ^ ^ * fc « 7 7 'J T - i/ a > V 7 b 7 x 7 fc 

Hff-f 5 fcfe fc , &ft©ft<fr X h y-Afc-ftto£9J9&trfca&lc7nfcytffc2&«Sft 

10 

[ 0 0 0 9 ] 

©J;DIS^l/^^OA-F')i7?ffifflt5i:t«M*ft^x;ib-v'3y7D^7A 

t &* <£ ffl £ ft & <> Lne,«77 | jy-^3yi;ai'-->3>7n^7AB, ^5A,« 

•>3 y7n^'7AT*J 5 tv^ttl-hW-ffi^^S't^t^o S & K , c ft P> © 7 7 'J 
-e/3>x=aU-->3y7 P n^^A«, /n- F")i7il (ha rdwa r e f ea 
t u r e s) 'x © 7 ? -fe X £ S £ T* £ 0 , cnSOA-FfiTllli, *XFt^ 20 
l/-f 0?->XfAEJ:()77yy-v'3>'X5al/-->3y7n7*7Alcit}LJ^ 
tl5o — #1 £ IT, *XFt^l/-r^^->Xri i lT77' l jy->'3>iLtl^t 
§ x 5 a U- %/ 3 > 7d k&s mn^> b'yttStSC ttf-?Z 5o x5 
il/-->3yyD^7AOe!WAyF7i!i', l> < O © V 7 F'7i7H'tli:J:0*^F 
3>tra-*S/^ri»©7'a-b>y9-fr6»(t*ftT*0, ZVfctb, * X h 7* a -tr >y if 
Wn*atT^*^IBIfcffll^^X5aU-5/3>7 , n^5AOWI^M>'F5K»BiJ*ftSWf 
BBOIBtc^^^ffl^itSftSCfea&So »J <D * 7* 3 > « , x5aU-S/gy7*o^5 
ACiSnyifa-^yXf AO«WOfcft(D*#-F?:*X F*^U-TY >^->Xf 
AA^;^-/Hf ICtf iitfC ^^Tt5t&ftLTX= a U-->3 y7'D7*7A^3y 
lfa-?->Xf Ai:A-F-7i7^«fflt5ili:t'feS. 30 
[0010] 

IK ft j£ , A^;^-/Hf l*©^t'J3ltttlcx; a i/-FSn§3>(fa-?-> 
Xf AO^'J^H^iltStit'fcS. I = al/-FJn§3>t:2-?i/Xf AO 
- 3 yfc&fi-TS /\ -< - ^ -< -»f ti — a tC , *Xh3>tfa — *->X-r 

AO^-^f-7/l'i^XF*^l/-TOy->Xf AO^-^f-7il/*^;S»;7- 
U y 7" t ?> <fc 5 £ , *7h3yifi-i' , >xf AO^-^f-y^tllffuatts 
e C©77a-?-©lo©B86ft£tfs / W - / W If 3 - F fc <fc ^ ft £ IS « ^ 5 t - 

# tf, yx F*^u-f-f v^-yxf A©'<-->"f-7;i'KV7 t:>ysn&^<:i:T'$ 

3 „ i^^-FSftSny^a-^^XfAii', A>fA-/Wlftf*XF3vei-$ 40 
i/XfAOA- F^i7lt">Xf AO*X h £ LTi^T^St fc£^f®Lft<^;fca&, 
i&fc<!)J;5lc45, LfctfoT, /W/<-/W1f C<- s> r~7;Mi, frxhnytfa 
- # -> X f A © ^ - i>' r - 7 ;!/ i; ^ £ K « £ ft L * ^ . /% -f - / W *f © ^ - *J f ~ 7 ;1/ 
« , /n -T - / W If i ft © 3 - F 43 «fc tf r - £ © v >y tf > 9 % h> T ^ 3 o 
[ » BJf © M * ] 

[001 1 ] 

y x h * ^ u - r -t- > y ■> x f a o 7 F1/X7 7 g>iftf, /w^-zw-tfitton - f 
fc<};a*f I -^©v-y^>^$ftfc^m3>i*icW-r?.7FUXOv-ytf>^^#tr;:i:^fe 
5©?, A^^-/Wflc<):5yXFt^l/-r^>'7"v/Xf A©^-^7-7;l/©5 7 50 



(10) 



JP 2004-531788 A 2004. 10. 14 



- U V 9 It , y X h * ^ b - r > y > X r A © 7 K U X V >y If > y m ■< i\ - / W If © 

7 Fuzv«j/tr>iri:tt^-r«Riflitt*±ifs 0 cons 
o 1 o © v y a - a > #\ yxFt^i/-f-fy^->xfAoli^t | Jov7^>'y 

[IS*)i?at5ftfeO¥i] 10 
[0012] 

a«K«JDAtL-f S (decoupl ing) fc H> ©atfi K 3 . * 8 13 © £ S fc J: n 

m (s e t t i ng) 5M*l!5o Cft5<Z>:/ci-fey9-»£tt» /\ 4 i\ - / W If fc «fc o T 
±ISHSHtc«#$n?) 0 /\ -f - /W -if tt , cn6C7'nt7lt88f i&yxht^l/- 
y*>y*>*yAfc«koTffl#Stt5y7h*x7 7l>-y>a?fctty-*«£fclH* , *-5 
lffl©7*n-fe'y9-»5£fc:$a*3 0 cti60y7h"7i7*-f>Sftttf-*iItt, 
0»J ft *5 J: if fj £ > F 5 /I/ - f - y t *< - -7 t - 7 Jl t * M t £> C t T* # § o 7 a -tr <y if 

LT> *7,K^l/-T^^v'7,fLli, 7n-fe-ytf©7p-t:>y+>- 20 

V7F7x7;l/-^y^fc:ttx-^«iilcMjlL> *7, h*^l/-f ^ V^i'XfAtO: 

Ctt6©7P^v1fK3£*7o*«ytf©HWfcU-7X*K:»#&tfo 
[00 1 3 ] 

m - /< ^ -9 s 7 n -tr -y -9- K |g L T ^ § ffi H * « , m -Y - > W If © * - 7 r - 7 ;l/ 

a y x h ^i/-f -f > y 7 x r a © ^ - 7 r - 7 ;i/ * * = 5 - y > y t 5 , /W 
- ^ w if © ^ - 7 r - 7 ;i/ a -f ^ - ^ 4 if a - f g & © v -y tr > y $ n tc m pft * % is 30 

-/Wy©^-7x-7/l/©lig©$£*l5)&t3fci6C«> yxF^^lz-fOi'yX 

fAo^-^T-^^Kosioei, yx F*^b-f ^ yyv'XrArt^vy tf>y 
^ > y s n fc « m k * - ^ 5 >y 1 * 3 m £ e » m -f ^ - / w if © * - 7 y - 7 ^ # n »j *) 

[0014] 

*wiffl#c^^^nT^5fiawic«f3«tBis^-r§73iiti, yx h^^u-f-^ > y 

->X7 : •A^^ c };oT*i«T't?.^■^<*^©1it6^i:■^^^T, yx F*^l/-rO^'7Xf A 
*7*n-b-y9-f:«J:»)«l8ftSliE7?t««J:5fd-5i:^3jSCZ?W*iJ?*S. CCDJj&lc&V 40 

-f-f vyi/XfACi^tlSSdl^ 7*ui:7**^*Xht^l/-T^yyyXf AC 

7"ny7A©A^/^-/Wf^M,tyx h*^l/-f-f >y->XrA{citgfc8$ns 

o 

[0015] 

* m m m k m m $ n t * 7? ffi » s , A^s-/uifif;iJi5ii/-v'a > y n y 5 
A © 9) t> Si u y - ;b , *xh*^i/-f ^y^yxf Aov-xa-F'\o7i'txs 

T^y^>'XfAli:«LTh7yX^71/>FaSST', 7"Dt7*A^*X h^^b- 50 
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. =r 4 y *f*s 7.7- A £ D 8i L , ^ ft # 7 o t y ^ £ ^ 9 ^ L £ fc « * n C IS £ L T 
[0016] 

* m & S Hfl 7F. $ n X ^ % 73 i£ $ fc > /:U*Xh*^V-T-f>i'->Xfi 1 i!) , > 51 ft 

1C & £> o 
[0017] 

^f-7;l'tfyx h * ^ U - r -f y^->XfAO^-^f-7*yl/*a^\ R 1$ tc /\ -Y - 
i W -9-" S ft o 3 - F * v -y \> y 9 x fr 5 i 9 fc & 5 c t t? h 3 o ccaiftKio^Ttt, y 

Xh:*^U-T^>^i/XxA©^-^T-7;l/^0EH©iSa3l£LT, yxht^l/- 
r f > 9 > X r A <D ^ - s> r - 9 >l t /n -T - / W If © ^ - 5> r - 7 ;l/ © n o jR £ ^tC 

■>Xf i»0*^l/-->3yKWLth7>X^7 1/>M*fet3, ^ ft tc <£ 0 , fXFt^ 20 

[0018] 

[0019] 

It5 C tic J; 5f 6tl5T*S5 9„ C CTBiO#!Sif Bl O « H * * * . 
[ 0 0 2 0 ] 

^ftmii, X*aU-'>3>V7h^x7A^ *X h 3 y ^a-^ ->Xf AO i !) fi^!/ 30 

5, # 12 W « , ^Xh^^lz-fO^^XfLEMU h7>X^7U> 

-Y ^ - > Wfl* » » * X h 3> t!a-?->Xf AOlffiWM8*5>>i"^l/-f ^ >^"'>Xf 
A * , K B$ IH , HaWJc^Bf-rSA^SfettWOffL, c<Dmm*s I5ib-->3^a 
^7A©A^f^-/Wf tt, * X hnytfa-^i/^fAOA - F^x7©i|lrt(Cl^ 
ft , ^ ft lc <fc t> , i;il/->3>7"D^7ii!i 1 , jfcXFnyfcTa-^i/X-fA 
0-SOA-K^x7ilCiIfi<ltifi<^:5i:i:tfTt5. 
[ 0 0 2 1 ] 

c ft 6 o K £ fi » rn-try^i'SfHT^Sf-^i/a-b'y^Ki^tffi 

a-fe>y>HcJ;^-t«Mt£ft, £ < ffi © 7 a -fe >y tffS^ * ft € ft © y n -tr y it -f * Jl 
T'tMt5Ct*^5 0T-, 7 o -b y +»" « SI fc R « (c , fhfftoynt^*^HT 

[ 0 0 2 2 ] 

1 ^7"t7 h©7n-feytftt«tfa-if:Rttt»&6 e 7 P t 7 i -3 t iff 5 tl 5 f- 
**J:tf7n-t<ytf07oy7Aa«>>*tt» S tSoT^nt Oa-1f«i*St 
£ a a-HftfBH:, i-f«l^tt5l^7 7* i Jy-->3>U^;^/ny7AlcJ;o 
T Mi ft T* t 5 # K % <D « P. ft T ^ 5 . 7n*ytftttt0:/n-feytfK:£©gl!>0 50 
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T©#<f IT* # So yntv^««fOX-/OWf«l* fe«W«l«IBOia3£». 7 7" 'J 

y LfrZT 2 t 7>^m%^-VWi&tT 7 V a > U<Jl<D7u 7? Lfr %7 t * Z 

^ffiT-fct^X-/OW1ftf®©iffl©7 , n*ytfi8£©#&K<fctK ItbArfV a 

- t 4 y 9 *s X t L It « fig L « 5 C fc V * 5 o 
[ 0 0 2 3 ] 

7 D -fc y *OX-/OWf KlOS£B, -«IC, ^ < Ofr© A f J 'J O 9 % © 1 OC S 10 
T ti £ 3 0 7 P p -b y It <D X - /WW if « ffi © 1 o © # x p 'J ^ 7ot7*©€-F77 
7* T* & 0 , 7* P -fc -y t>- tc > - £ © » tt M , UJJJ'^ny? AO*#- h, S 

lol^oTifftSi^^tSSS^ttS, 7" P fc y It « l§ © R £ © 8'J © # x P U 
#\ ftg]5M-F7x77?-trX£3iiJ01lt3R5£T-fc?>o ^ntv»#, LIS Lit. 7 n -fc 
•y+>-£, ^fr^a, ^i), <ti2©Atf}^7WWX&£©7 0 P^y+f©ftgB©^-F^x 
7©M©fflfl^fca&©^<Ofr©i*flsWfi*K£*tf#-FtS«, fc i: *ff , iifiiiK^ 

*«fi%^tJdti6oaffni(i*aas^, ft tit u * ;i> g fc a x - ^ /w -»f i> * ;v © 3 - f 
n 3 o 20 

[ 0 0 2 4 ] 

7n-ty-tf-0W*#tt©R£©9J©*^:Jytf» fl»JftfccfctfSiJ&;l>-^;/iiWy*T-fc3 

0 ^ d -b >y -9- flflj ft \z M M L fc •) £ fc 9J i& * * * 46 5 ft fc *§ ft , 7" a -fc >y * ft > 5! £ 

o7b^7/»*^*7 KU7?sifj*ff±L, mfc<z>mn-/\'-*y7 Ku^T^fj*m 

So ^ < o © 7° p -fc >y tc c> f> T it , ft ;1/ - y (i , — F n - F £ ft fc * * U 7 F 

UXtcgfrftSo Lfr L> IS i: A, if © 7° p -fc >y ± T- & , *tie><Dmifilf7u 

T*fe0, *ftfc©*m©ffi»i, 7'p-fcy^©X-/OW-y t M©-^T&3£#*.P>ft?> 

o 

[ 0 0 2 5 ] 30 

1 mtDT-zmj&m y$t>\ ^D-by9-o«r«i«J6©aiJ©*-r=f 'J *«i«"rs. 7*pfc 
y^«ffi©^<o^Or-^m3i(t7s*1-f*T7 p P-tr7-9-rtttSilflT-f^^©T, C ft 5> 
©x-^flUBttiffitttSBrtlct&ttSft, x-*MfC#t3#'fy*tf7'p-fc>y-9-l;:te 
|?n5o C 7*- *«IJfi©-W*^ 7°p -fc -v Ht © ^ - ^ x - 7* ;l/ T- £ § 0 C 
ft 6 © r - 7" ;P , 7° p -fc -y -t © fc iMc , M**'Jlff3f'\©fiS**'J7*'feX©glfc 

t<e>Ba^ ; e'j7 Kuxoii^eftiMoin^^its. fa* ? y\z&mz n% . 

^ - V f- - 7 Jl< £ ^ - V f- - 7 )l< KM t % $ J y 2 <DMJ5 ft , 7nt >yf ©X-/OW1f 
tt!B©-S5?fc«4:#*.&ft3. ±K«SHrtfcte»lSft37nfcytf©x-/</W1ftt 
!i©7*-*«lia©giJ©«IA^ W ft ;l/ - > # y^f-7";VTS5, 7 s p -b <y * ic * ft € 
ft©Wft/l/-f->©fcii>©#-r>**tSlft , r5±'3«trb5, T'nt^clSXJhft* 40 

-vm mftj\'-?y#jyz<OT-7)i'*mL7fi-t£ttf-e%5o m ft * -r > 

* S fc ft * h ;l/ f - 7* ;l/ H: , 7°P-t-y-9-^e.7^-bXnJ^^^Jft^> K5KSt57 F 
bX^^y^O'JXT^y^ttS. 7 , n-ty9-KttW*ftSffilft/I/-f->'#>f>#i: 
Wft;l/-^>^-l'y^7 1 -7*^©W75A^ X-/^Uf«iO-ait'S§i:f x.f>tl5. 

[ 0 0 2 6 ] 

* X F * ^ b - f -f > y -> X r A (£ , - m E . 7° d -fc -y © & te , m ft fc J: tf 9J & ^ > 
F 7 ;U - 7- > tc «t 5 ^ ^ h )V S it * ^ > ^ 5: BS fi t 5 . fc t * If % 7° o -fe >y it , 7° 
D-fey"9-KHfP»c«fcSI»ll%«-a:* lffl©PvyF^Saa-t ; 5<i;'5^^^ftfc«^(c, 7° 
p-b«y+>-(t> -Ifn fc«k SHtJ|©ffl|ft«JR5 Wft/N> F 5^-f->*"Ptf Hit. * 3 t S C 

i: J: 0 , 7" p -fc -y +>• a , f P -fc >y * tc « M $ ft fc ^ ^ F ^ K «fc o T L ^ $ ft fc 0i ft /n 50 
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y F 7 ;1/ - f- > * f t>* Hi t c t "P t § o ft fc> 9 fc , 7Pt7tli, $J ft & tt <£> fc #> IE 
Li^JtAy K 7 © fc tf> <E> $1 ft ^ * h fry- -7 /I/ £ X * * > L , & f T* , 3§ ffl oj ffi 5: ft 

m > f 5 c m m t s m ft * * Mb $ fc & ;iw > * £ $ $ l r w ft ^ > f ^ £ ^ a* as ir c t 

[ 0 0 2 7 ] 

* X h * ^ u - t 4 y f *y x t A ft * X h 7 p -b >v -9- o m a 94 9P fc * 5 * £ tt , * X F 
t^l/-f^y->Xf Ali, * X h y a -Ir v "9- © fc 46 fc , *Xh/nt^i^SH 
*ttfc<fcoTtf#-h<*ftTl^£0!lft^* F^fc.fctffffiOf'^T©'^ h/V%S8t5, 
/n-fe7^tf(Un*ttClILft!), S tt ^ - 5> r - 7 Jl )\> - ^ > * ^ - S> r - 7 ;l> ^ 

* Mb & H © ^ ? h ;1/ fc «t -3 T #!& $ ft 5 g'J - f- > fc 7 £ -fc X "T 5 &g ft $> £ *§ £ fc 10 
« , •/ p -t <y -9 « , frxvx^u-f-j y?i'Z.7-i*<Dmft'^y Fy%Mfit%<, 

[ 0 0 2 8 ] 

-i'ay^n^Al 4 , *X Fn>-ea-?->XrAA-F')i7lfcli7'nt7* 

1 6?:x5iU-h-r?>o fXh7^'jy->'3>^ny7itf, ^'Xl-t^l/-fO 20 

^r-->3 >2 0*'-itC*X h*^l/-fi' >^'>XfA 1 Zfciy-tX h3>(fa-^ 
•>XfiA-F^i7 1 1 i:fiS»tt©ai/>*'«b-'r^>^">X-rA±*iiff-rs«t3 
Rtttnt^fttLTt, y*X h7'/'J^-->3>2 0ti3>tfi-^>'Xf A 1 0 ± % 
B107- + T {'fttft^Ttt, yXFt^l/-fO^->XfAl 8ft 
, $X Ft^l/-f^^->XfA 1 2i&t&, ^<O^OiIfeitfy7 h'?i7H' 
t*Mt*XF3>lfi-^->XfAA-F^i7 1 lfr^SStlT^S. COM 
ftyrgifc £ ?> > yXFt^l/-f^^5'XfAii*XFayifi-^VXfiA-F') 

x7 i i fce^ic)ifflt^ci;%s*?>«^ic, wtmmis&tf&m-tvmmftmxzn 30 

[ 0 0 2 9 ] 

0 1 *XFt'«l/-f-fyyS'Xfil 2*', *XFa>tfi-^->Xf AC 
7 P -fc -y +f £ £ t? * X Fa>e a -y->Xf Aa-F7i7 1 1 © ft fi W ® ft *"J IP ft fc & 
So *XF^^l/-f O^^XtAB, ihXh^ytfa-^yXf A©7"ut7l}-Oft 
tb fc , 7"aty*«lOl><Oi!i>ORS*lliLT^i, i: * fcf , t«X^^l/-f-f 
^'yXfAi 2 tt , * x h 7° p -fc -y 9" © ^ * h ;b r - 7 )\> rt S fc » U S> X 2 fc H *» ti 

ti^iioi)iA>F7^n*, i « o w a m > f 5 , ^-^x-^i/^F/i/^ss 

1 L fc n] fig £ 5 o Lf;* ( oT, 7 D * y it #00 ft /\ y F 7 "f tf tH L M & m > F 7 «f 

tH L , $ftB^t';Sli*ffllll/*lfti^tt, i:n?.<D(¥t)FtbbcDfc46<D7 , 'P-b-y-9^ 40 
5£ # , *XF*^l/-f -f Vy'v'XTAlCioTSfffiW^-X-Cllt^nS, *XK^ 
U - r ^ y 9 V XT- Lft, ^P^-y+)-C»X-/OW-9 , ffcB!tf1t«fi8 0^S^®±ttfcO 
T* , *X F*^l/-f y^-yXf Att, *XhP>kfa.-^i/X-rA07 p P-b-y9©fi 

a3ii]»i^fcfe§^m^So 

[ 0 0 3 0 ] 

* JSBOxSaU-J'a^ajfilciftli, l?aU-5'3y7'D7 , 7Ai*(i, /aty 
^fciO : l©*XF3yi;i-?yXfAA-F')i7 1 1 © P fffi « M » ft 5> * X F * ^ 
l/-f-{ y^^Xf-AJ&^aWfcWKitS^Sfctt^OSIL-rSi: t©T't5A^^-A- 
'f f 5;tt5 0 lial/-i/3>7Dy7Al 4 OA-f A"-;Wf li, * X F f P -fe -y 
lcioTffifflSti*^n;l/fe<):tfl«7Fl/X*^ynM»f5!^ tnft^tUIIBf 50 
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. rt£&#f5C tic* t> HSgjajf* r >y 7 £ it file f 5 . * X h n > ¥ a - * is X f A © Sf 

y 7 A «D ^ - / W if % * X I- n > £ a - # i/ X r 2* ic H a m K & ffi. t Z> £ tz It *S 
t %fcisb\c /\^f A- A 4 *f fc J; -dX t t>n% Xf <y 7 '<Di?itft0tf , 0 2lcg?ftT^5, 

'> * < £ ^ < o e 5 *j w z m m l tz i> « £ « s /\ ■< a - / w if « > xf-y/H 

* & § o *fi W <D - ^ Ji ^ K. * n «\ 7 s a -tr «y -9- tt » W ft * * h ^ £ fc fat m ft^ * h /l> 

;V«ISll!t5, © iiS H > *XbyntyiJ-O^DtytRStt, y^l>t^l/-f 
^^VXf AOl-f U^/l/O^a-fe-yiftffifc, x5ab-->3y7 P P^7AO/N'r 
/<-/WifeM3 - S#fil'^'l>#a8fc©ffl#£t>i£fc£8lSti5o ^-^-rscttc.fco 
/» >r A - > W if B s •/ a -t y if <D M 9i * U 5> X £ ft ic , 0y ft /n > F 5 E *t ? § ^ * h ;H3 
JctffifiOTKbX^l'^^, fj ;!/ - f- > , i5il/- < >3> , yo?7A©A'f^-'W 

[ 0 0 3 1 ] 

- A> W if $ tz it ft *t U ^ ^ © 83 £ T* 5 © T* , x 5 a P - a y^ayHOA'f^- 
li> Hg|$ti/f/p-tr-y»f^^©-r^Ttcov>T-/a-b-vif©^aaiiJffli^ ; &-r?.o 

SK±t)Ttt}6*n5«ftKO^T, In S W fc * X h3>fcfa-*>'XTA£D/N-K t 7x 
7»fll<9*J»AK:fc3. 7at7^S£<!)lft8<!)xiil/-'>3^o) , 7i i l 4 © m 

D^ 7 A1 4©l^)Ol)SilIHTiSn, ^Dt»;t*J:tf*7hA-F'7i71 1 
MDllII'J y^%St5feCt LT^?nT^5. 30 
[ 0 0 3 2 ] 

*XF/N-Ff i7 1 1 OlSalz-i/g ^yoy^iOiliMSO-ffilillT, ^"J ^ ^ 
Z (Dmfflt£fc&% ZMnte, "f p -fe >y if It , iiil/-->3>7 J a7'7AOA-{A-/U 
if tc i o t 11 « 5 n 5 09 ft m > K 7 * if tf m 1" c n $ % 7 a -b >y if tf, Hfi^t'JfF 
UX^tia^ ; eU7FUXlciBIR-r5J;7ffD*ai^n?>^-&B, ^ d -tr -y if , yxh* 
^l/-f f>y'>Xf Ai:lIt§^--/ , 7-7;UC77tXt5„ Lfc^oTs ^ D -t 
-yif«*0^<OK^^5E««nT, ^©e«, ^ o -b -y if tt , fXF^^^N^ 

[C7nXLT^5o % (DC tick*) , ? XV * <V-T << > 7.T kft, a > If a - 
^i/XrA^D7 , D•b-y^fi:J:0)i^«^ciifeaW^cISS•et?)J:9^c^t)^ *XF*^l/-r 40 
^y^v'XrAf #(Ct3ftt3t3yifa-?v'Xf A©7"at7^A^yXh^^l/-f 

^y^i/^fA*^«t« c i<:?n5^%«fraA^<4S. wnoi^a 

, << A - / W if <0 fl«J y| m > F 7 « ffiJ ft S * Si *> C *« T* # 5 6^, S fc It /\ ■< A - / W 
if©^Jyi./NyF5(iyxh^^U-r^>^^Xri»OPy1-''N>K7*ei)T*t, ^ n £ 
J; 0 , yx^^lz-TO^^rAli, 0Jy1-i¥tffflL£*Xh*^U-r-fy? , ->X 
fAV7h'7i7l/'ft*Ii;TlIS*8*B« , 4<, ffi|y1-**»»5Ci:*<1?**J: 
■5 ^: § 0 
[ 0 0 3 3 ] 

03tc^^n5J;9lC, *XF^'5l'-TO?J'XfAl 2 tt , *Xhn>tfi-^'> 
XtAcO/n- F 7i7 A^^MC^Ki^hT^St) If T?tta^. lfiOT'o-b-ylfK^Jfe 50 



JP 2004-531788 A 2004. 10. 14 



. if LT /W /<- /W IfK «fe t3 T MS nfcHaSfJ»Oi^m> A^^-^Uf 22tf, 3> 

« * ?) * ^ o * X h^^^-r^ >y->Xfi s tf3>^a-^->XfAOA - K "7 x 7 C 
■ « , T*«lBB#*tt»tT^«BIB>t«tt, * X h * ^ b - x ^ > ~> X T A . 3 > t! 

a-^^^rA©na»j»rt?*^n{f*6*^. c © c t « it j£ -r § v> ic it , * x h 

* ^ U - T > ^ 5/ X r A « » -H#WK3>£a-**>*tA©/n- Kf i7KilWK 
?l US L & # ft &* & £ & ^ o l> o A/ * X ht^lz-f-f ^^J/^fAtflSa U-->a 
yyD^7iCJ:9TB#«nftl**^7t«i, x 5 a U - f a v f a y y A « , x 

^)Hiai^BSaTt§ 0 10 
[ 0 0 3 4 ] 

02©i5itft0fcWLT, '^SOf, A-T^-;Wf 2 2^, :/D-fey 

fi#«ftt^«'<{' h;l/43J:tf«fiO*i'>**^tU3^6*}R-ra. C ft £ © 7 k u x « 

v a«au^x*«BfKfitf«ti&sn, c n % <d •? u -t v v mfeic n t z> mmmm * * 

X ht^lz-r-f y^i/XrAlcjifo * X h * ^ U - r ^ y^^XfiA'^ot'y^ 

6iiattK«»r*nT^*i*iii«t»tt, t^K^b-f^y->xfAi 2 © nasj »? « 

yi/XrAl 2 « , lffl©:7P-fe>v9-^5£tffigS2ft, * ©IB S, ^ < o O /\ - K * x 
V „ lia»tf*Xh*'<l/-f ^^v-XfAl 2 tC jfi £ ft fc « £ « , *Xht^b- 

T-fy^^xfii 28, n $ ic > i m<D;\ - f y xTtyxfmLvmmmwtfztiicMz 

[ 0 0 3 5 ] 

lialz-^ay/D^AlcU, *X h t^U-f^ >^"'>Xf A^IUTlSSn 
S» 0W, 9J&#* **'J IIKOfilO*7->3 >tJ±<T, -b -y 

7ili:j:56ffiy^ytfii;5. x5al/-^3>^P^vA^, ^Xh*^U-rO 
^•>XfAlKgSt5 7 7 i ;y-->3y7D^7AJ:LtBfft5f^(Cfe^TS, 7 

tSCtli, l5al/-F?n5 3 7lfa-3f>'Xf AOfc60tti±0|ij^T'fe5„ (/> 
o fc A, * X hJfr^U-x-i' Vy'i'Xf Atf7n-b7*Ol^on©'>!S:< fc V» < o 
fr&i&aWlctflD8tL<*4a5i:, i;al/->3 >7n7*7Ali, *XI-t^l/-fO 
^i/XrA©yp-tr>y-9-K^O^to , ?^^©^ , P-tr-y-9-K^^B^1-§c:i:tc t };t)> * X 
h -f p -fc -7 -9" £ 5 ft \c <k 9 & m » T? £ 5 „ ^ o A,7o t 7 ^ittfiiS^ns t 
% x5aU-">3>yp^7Att, 7nt7tlcx; a i/--> 3 >7D7 - 7A«S^©i 
© #J ft ^ * h ;l/ , * - 5> f - - 7 to \c m * T* t , * n K «fe t) » * X h * ^ 1/ 

-f ^>^->XrAtfi5 il/-i/3>7n7"7A*^7D^7+f^»I?tfti^(cg 

[ 0 0 3 6 ] 40 

#8iB©/W/<--/W-«f ©*J&**s itfflflaftSa&lcJ: 0, ^"X 

xt- Lic&?T^Mznzmft&£vm&fr(D!&m$><s}mtrj:z> 0 * ^ u - r * > -> x 

l/-f-f >yfXfAI/^*7-SO«ftSa5aSl*Ct«i7*5. - 0J tfs -tfp 

Ki5»jio««T*v, chsiiiu, ini:ioTffl^?nf;77^-->3>7 

D7*7A(Cl?n5Li:4< 1 ^^Iz-T^yy^XfAKioTi^llSo X = a U - 
5/ a V 9 5 A © /W - If tt , * - A -Y Hf ft r- 0IJ ft ;\ > K 7 £ M % 1- 5 &£ 
& < , ?lf M?Mn*yxht^l/-f^yi'"->X7Ai:iti:t^f?§. LftA'o 
T^s^n^ct^ic, yxh77u^-->3>7D^7Atit), lisnfe/nt'yf 



JP 2004-531788 A 2004. 10. 14 



[ 0 0 3 7 ] 

* * t VS. n 0 T-«5o Xf'y7'4 0T* > /w /< - / w«f a , yxh*^u-y^>y^x 
h^^b-x^y^*^Xf-AO^-^r- - 7;V'\<D«ii^<0lS^, yxh^^l/-f^ 

-f-r >y'>xfi.iD^-^f-7i^isii:s7-y>yt§A s , ^ << * - > w * © ^ 10 

t^t^aigffii^^ttSo / w< - / w -if a , ft t «\ yxh*^u-f 

•> x f a o ^ - f - 7 ;i/ © v 7 y y ^ ti ft ^ - * s < ^ w /< - / w if <d ^ - s> r 

*» & 5 t f J KIT t 5 o 
[ 0 0 3 8 ] 

m << /i, - A J if , y x h^^l/-f-/ y f i/ X r A © ^ - s> r -7 © ^ M E <fc o T 
31 £ jg j: S ft ft gi£ ft ^ t fJ Wr L ft m % it s A^^-/WfO^-^f-7;KoEI 
t4 S T* 14 * l> ( X r >y 7° 4 4 ) „ /\ /< - / W If tf* yxh^^l^-r-C^y^XrA 
O^-^f-^^KOf IKiO, # X h3>t!a- : j!->XfAO^-v l r-7;l/t©i 20 

A" 5 jg t 5 £ W W\ b ft if £ 14 , /\ -f /< - > < f* If (4 , Xf 77"4 6T^O^-^f-7;H 
SflUSTL, ^OIS*, M-T^-/Wlfgf*©3-KfeJ:tf7*-*tt, /W /<-/Wlf 

<d ^ - x - t )\> © gij © n m k 9 ii -r s £ ft a v -y e y y s n s . y x h * ^ u - y 

-/W-!fco^-v ! r-^;l'^»SiJt)ST-r5i:©7°u-trXt4, yx^^l/-f ^y-> 
XfA©*^l/-v'3>'KjltLTF7>X^7b>'FT**5, # S * £ IC, o ft A, ;n 

o^-^f-y^tfBSoaT^ns^ y x h * ^ u - r 4 y y x y a 

© ^ - r - 7* ;b & , t & •>£> m - A +f c7) ^ - 'J f- - 7 jl t M £ t & ^ 0 
[ 0 0 3 9 ] 

*58^f4> *(D&mtf. l£on^t;i-^>XfA7-tf # K I n t e 1 8 30 

0 X 8 6 7- + f f Oi$il/-'>3>li:i^?n5t?)f tsLZ. 
tt:IS?nTl^i5al/-->3 > ft ffi 14 , 7 U M y V <T>rf u -fe >y iffS^O 5 % 
< tfel/^OfrClLT, *Xht^l/-f -f >y->Xf AA^O-b'yf *^ h^>X^ 

[ 0 0 4 0 ] 

[0ffi<Dffi*4^W] 

[ 0 0 4 1 ] 40 

[0 1 ] * X ha^lJa-^J'Xf Art*ifft5X5aU - h 3 y tf a - ^ ->X 

[02] x5ab-i/3>yn^7A<D-'N^A-/Wif , ^3yt!a-^i/XrAOyD-b 
y9-KttaWtc|S^t5fti6<0*S**tSI[nH7?fe*o 

[03] A^f^-zWif^ayKa-iOXfAO/ntf '!l , KliiWKfi^«nTl>5 
X5a U - h Jninyifa-^ 5/XxA<DSg ; ?<DlSaB!l^*^ , r0"Pfe5o 

[14] yxh*ti/-f-f vys/xfAo^-ff-^/^vyuy^tsftftostt 



im 1 ] 



(17) 

[0 2] 



JP 2004-531788 A 2004. 10. 14 



Jt — 



-16 



z 


I 




z 


\ 


fcX^U-r-rVi^TA 






*XhA-F9x7 



A<A , -/wif#7at7tfi'i>x*rtc 



A*A'wWtf*7'Ptytfl/5tt*AC** , Ja»& 



10 



[0 3 ] 



[0 4] 



¥ 



i 



-16 



I 



22 



,12 



**hA-K3x7 



10 




40 





A-Ot-A-ftf 











-45 



(18) 



JP 2004-531788 A 2004.10.14 



(12) INTERNATIONAL APPLICATION PUBLISHED UN DEB THE PATENT COOPERATION TREATY (PCT) 



(19) World Intellectual Property Oreintzatkw 
[mcmadonal Brucsa 



HQHuiiEGiiiiinnniiiiiiii 



(43) International Publication Date 
27 June 2002 (27.0d.2002) 



PCT 



(10) International FgbUcatloo Nomber 

WO 02/50664 A2 



(74) Attests: FULCRUM, Racer, J.; Biker Bolts L.L.P„ One 
Shell Plaza. 9 10 Louisiana. Hottaon, TX 77002 et al (US 1. 



latenurttraalAppUeatlaNgmbcr: PCTAJS01M9217 



09/747.492 
09/906J92 



19 December 2001 (19.12J001) 



2> Daxmhej2000C21.l2.2fma) 
16 July 2001 (16.07.2001) 



) Applicant: CONNECT1X CORPORATION (US/US); 
2933 Campus Drive. Sune 100. San Mateo. CA 94403 

(US). 

) locator: TRAUT, Erie, P.; 3 Iri* Lane, San Cute. CA 
94070 (US). 



(81) Designated States (national)-. AB, AO. AL, AM. AT, AU. 
AZ. BA, BB. BO, BR, BY, BZ, CA.CH, CN, CO.CR.CU, 
CZ, OB, DK, DM, DZ, BCEB,BS.FI, OB, CD, GB, GH, 
CM, HR. HU. ID, IL, CM, IS, JP. KB, KO. KP. KR, KZ, LC 
LK, LR, LS, LT, LU. LV. MA, MD. UG. MK, MS, MW. 
MX. MZ. NO, NZ, PL PT. RO, RU, SD. SB, SO. SI SK, 
SL.TJ. TM, TR. TT, TZ, UA. UG. U7, VN. YU, ZA, ZW. 

(Si) Designated States (regional): AREPO patent (GH. GM, 
KB, LS. MW. MZ. SD. SL SZ. TZ, UG. ZM. ZW). 
tfemswn patent (AM. AZ, BY, KG. KZ, MD. RU, TJ, TMX 
Bnropean patent (AT, BB, CH, CY DB, DK, ES. FL FR, 
GB, OR, IB, IT, LU. MC. NL, PT, SB. TR\ QAPI patent 
(BP, BJ, CF, CO. a CM, GA, GN. GQ, GW, ML. MR, 
MS, SN, TD.TG). 



without international Karch report 
apm receipt of that report 



and to be repibiuKed 
on next page J 



: (54) Title: LOGICAL SUBSTTTUTTON OF PROCESSOR CONTROL EM AN EMULATED COMPUTING ENVIRONMENT 



< 
O 




(57) Abstract In an crank ted competing cDvirocuneiit, 
a method » provided for logically decoupling the host 



sot of the anuJjtkm program replaces some of the pro- 
cessor settings of the p 



vided by the goat operating ij ctem; The rcpstced pro- 
cessor settings are written to memory. During this pe- 
riod, when the processor colli ■ software routine or ac- 
cesses • data ttrocmre euociAled wttn the replaced pro- 
ceitar letting, the processor wiD call or access a soft- 
ware tontine or access a dsaa structure associated with 
the gaett operating system, bypasmg (he boat operat- 
ing system and commizucating directly with the gnest 
opexating system. When the host operating system is to 
b« lecoupted to the proceiiw, Ihe processor jetting* lhat 



prints registers of the processor. Daring the period that 
the hypervisor is conpfed to the processor, the page ta- 
ble of the hypervisor is established such that it largely 
mirrors the page table of the gnest operating system. If 
a change to the page table of me gnest operet b\g system 
causes a conflict between the page table of the finest op- 
erating system and the page table of the hypervisor, the 
page table of the hypervisor is reallocated in a manner 



.J 



(19) 



JP 2004-531788 A 2004.10.14 



wo 02/50664 A2 IMIMglligBDHDMljj 



For rwo-Utttr coda and Other abbrrvUttiom, refer to tht "Quid- 
once Nota on Coda and Abbreviation,' appearing at the begin- 
ning oftach regular tow of the PCT Gaxttt 



(20) JP 2004-531788 A 2004. 10. 14 



WO 02/S0664 PCT/USO V49U 7 

1 

SYSTEM AND METHOD FOR THE LOGICAL SUBSTITUTION OF PROCESSOR 
CONTROL IN AN EMULATED COMPUTING ENVIRONMENT 

TECHNICAL FIELD OF T HE INVENTION 
5 The present invention relates in general to the field of computer system 

emulation end, more particularly, to a method for transparently decoupling the host 
operating system from the processor of the computer system in favor of control by the 
processor by the guest operating system. 

10 BACKGROUND OF THE INVENTION 

Computers include general purpose central processing units (CPUs) mat are 
designed to execute a specific set of system instructions. A group of processors that have 
similar architecture or design specifications may be considered to be members of the same 
processor family. Examples of current processor families include the Motorola 680X0 

15 processor family, manufactured by Motorola, Inc. of Phoenix, Arizona; the Intel 80X86 
processor family, marmractured by Intel Corporation of Sunnyvale, California; and the 
PowerPC processor family, which is manufactured by Motorola, Inc. and used in 
computers manufactured by Apple Computer, Inc. of Cupertino, California Although a 
group of processors may be in the same family because of their similar architecture and 

20 design considerations, processors may vary widely within a family according to their clock 
speed and other performance parameters. 

Each family of nucroprocessors executes instructions that are unique to the 
processor family. The collective set of instructions that a processor or family of 
processors can execute is known as the processor's instruction set As an example, the 

25 instruction set used by the Intel 80X86 processor family is mc«rnpatible with the 
instruction set used by the PowerPC processor family. The Intel 80X86 instruction set is 
based on the Complex Instruction Set Computer (CISC) format The Motorola PowerPC 
instruction set is based on the Reduced Instruction Set Computer (RISC) format CISC 
processors use a large number of instructions, some of which can perform rather 

30 complicated functions, but which require generally many clock cycles to execute. RISC 
processors use a smaller number of available instructions to perform a simpler set of 
functions that are executed at a much higher rate. 
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The uniqueness of the processor family among computer systems also 
typically results in incompatibility among the other elements of hardware architecture of 
the computer systems. A computer system manufactured with a processor from the Intel 
80X86 processor family will have a hardware architecture that is different from the 
5 hardware architecture of a computer system manufactured with a processor from the 
PowerPC processor family. Because of the uniqueness of the processor instruction set and 
a computer system's hardware architecture, application software programs are typically 
written to run on a particular computer system naming a particular operating system, 

A computer manufacturer will want to maximize its market share by having 

10 more rather than fewer applications run on the microprocessor family associated with the 
computer manufacturer's product line. To expand the number of operating systems and 
application programs that can run on a computer system, a field of technology has 
developed in which a given computer having one type of CPU, called a host, will include 
an emulator program mat allows the host computer to' emulate the instructions of an 

15 unrelated type of CPU, called a guest. Thus, the host computer will execute an application 
that will cause one or more host instructions to be called in response to a given guest 
instruction. Thus, the host computer can both run software designed for its own hardware 
architecture and software written for computers having an unrelated hardware architecture. 
As a more specific example, a computer system manufactured by Apple Computer, for 

20 example, may run operating systems and programs written for PC-based computer 
systems. It may also be possible to use an emulator program to operate concurrently on a 
single CPU multiple incompatible) operating systems. In this arrangement, although each 
operating system is incompatible with the other, an emulator program can host one of the 
two operating systems, allowing the otherwise incompatible operating systems to run 

25 concurrently on the same computer system 

When a guest computer system is emulated on a host computer system, the 
guest computer system is said to be a virtual machine, as the host computer system exists 
only as a software representation of the operation of die hardware architecture of the guest 
computer system. The terms emulator and virtual machine are " sometimes used 

30 interchangeably to denote the ability to mimic or emulate the hardware architecture of an 
entire computer system. As an example, the Virtual PC software created by Cormcctix 
Corporation of San Mateo, California emulates an entire computer that includes an mtel 
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80X86 Pentium processor and various motherboard components and cards. The operation 
of these components is emulated in the virtual machine mat is being run on the host 
machine. An emulator program executing on the operating system software and hardware 
architecture of the host computer, such as a computer system having a PowerPC processor, 
5 mimics the operation of the entire guest computer system. The emulator program acts as 
the interchange between the hardware architecture of the host machine and the instructions 
transmitted by the software running within the emulated environment 

A hypervisor is a control program that exists near the kernel level of a host 
operating system and operates to allow one or more secondary operating systems, other 

10 than the host operating system, to uso the hardware of the computer system, including the 
processor of the computer system. A hypervisor of an operating system emulates the 
operating environment of the secondary operating system so that the secondary operating 
system believes that it is operating in its customary hardware and/or operating system 
environment and (bat it is in logical control of the computer system, when it may in fact be 

15 operating in another hardware and/ar operating system environment and the host operating 
system may be in logical control of the computer system. Many operating systems 
function such that the operating system must operate as though it is in exclusive logical 
control of the hardware of the computer system. For multiple operating systems to 
function simultaneously on a single computer system, the hypervisor of each operating 

20 system must function to mask the presence of the other operating systems such that each 
operating system functions as though it has exclusive control over the entire computer 
system. 

If it is desired to emula t e the entire hardware architecture of the guest 
system, it is often useful or desirable to make maximum use of the hardware in the host 

25 computer system, including, for example, the memory management unit, (he context 
switching hardware, the exception handling vectors, the interrupt routine pointers, and the 
floating point units of the host processor, and the memory of the host computer system. 
This hardware, however, is normally under the control of the host operating system and is 
shielded from access by user-level or application software. An exception is an event 

30 occurring in the computer system that cannot be rcsorvod by the processor. An mtorrupt is 
a request sent to the processor to temporarily interrupt the current instruction stream to 
perform some other operation 
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One option to avoid this difficulty is to employ an emulation program that 
does not attempt to use the lower level hardware of the host computer system. Thin sort of 
approach is often used in the case of an emulation program that resides as an application 
program and runs oo the host operating system. These application emulation programs, of 
5 course, are subject to the performance penalties of being an application program that runs 
on the host operating system of a host computer system. Further, these application 
emulation programs only gain access to the hardware features that are exposed to the 
application emulation program by the host operating system. As an example, an emulation 
program that runs as on application on the host operating system can include an exception 

10 handler. The difficulty is that the exception handler of the emulation program is separated 
from the processor of the host computer system by several software layers, creating a 
latency between the time that the host processor issues an exception and the time that the 
exception is identified to the exception handler of the emulation program. Another option 
is for the emulation program to share the hardware with the host operating system, 

15 assuming that support for the sharing of a computer system by an emulation program can 
be written into the hypervisor of the host operating system. 

Another difficulty of using a hypervisor in an emulated computing 
environment is managing the memory space of the emulated computer system together 
with the memory space of the hypervisor itself To improve the operation of the emulated 

20 computer system, the hypervisor will typically seek to operate the page tables of the host 
computer system such that the page tables of the host computer system largely minor the 
page tables of the guest operating system. One difficulty of tins approach is that tho 
hypervisor code and its associated data is not mapped in to the page tables of the guest 
operating system. This is necessarily the case, as the emulated computer system is not 

25 aware that a hypervisor is hosting the system on the hardware of the host computer 
system. As such, the page table of the hypervisor does not completely match the page 
table of the host computer system. The page table of the hypervisor includes the mapping 
of the code and data of the hypervisor itself 

The mirroring by the hypervisor of the pages tables of the guest operating 

30 system raises the possibility that the address mapping of the guest operating system will 
conflict with the address mapping of the hypervisor, as the address mapping of the guest 
operating system may include the mapping of addresses over the mapped locations of the 
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code and data of the hypervisor itself. One solution to this problem of conflicting page 
mappings is to alter the page table of the guest operating system when the mapping of the 
logical memory of the guest operating system conflicts with the mapping prescribed by tho 
nearly identical page table of the hypervisor. Altering the page table of the emulated 
5 computer system is undesirable, however, in that it would introduce to the emulated 
computer system an unexpected change to its page tables, possibly introducing other 
incompatibilities or mutts in the guest operating system. 

SUMMARY Of THE JNVBNUQN 

10 The present invention concerns a technique for logically decoupling a host 

operating system from a processor of the computer system. According to the method of 
the present invention, a hypervisor of an emulation program reads in a set of the processor 
settings of the processor- These processor settings are saved by the hypervisor to main 
memory. The hypervisor replaces these processor settings with a set of processor settings 

15 associated with software routines or data structures provided by the guest operating 
system. These software routines or data structures may include exception and interrupt 
handler routines and page tables. As a result of the substitution of processor settings, the 
host operating system is decoupled from processor control in that at least some of the 
processor settings of the processor are associated with software routines or data structures 

20 provided by the guest operating system, and are no longer associated with software 
routines or data structures provided by the host operating system. To recouplo the host 
operating system to the processor, the hypervisor reads in the saved processor settings 
from memory and writes these processor settings to the appropriate registers of the 

25 During the period that the hypervisor is coupled to the processor, the page 

table of the hypervisor largely mirrors the page table of the guest operating system, with 
the primary difference being that the page table of the hypervisor includes the mapped in 
locations of the hypervisor code itself. To avoid conflicts between the page tables of the 
guest operating system and the page tables of the hypervisor, the page table of the 

30 hypervisor is reallocated if a change to the page table of the guest operating system results 
in mapped in memory location in the guest operating system overlapping with the mapped 
in location of the hypervisor code in the page table of the hypervisor. 
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The logical decoupling and recouping method disclosed herein is 
advantageous in that it allows the guest operating system to be more closely aligned with 
the processor for some functionality that can be provided by the guest operating system, 
hi this manner, exception handler calls, interrupt handler calls, and memory management 
5 calls need not be passed from the processor to the host operating system before being 
passed to the guest operating system. Rather, these calls from the processor ore passed 
directly to the guest operating system via the hypervisor of the emulation program. 

The method disclosed herein is also advantageous in that the hypervisor or 
decoupling tool of the emulation program need not have access to the source code of the 

10 host operating system Rather, the hypervisor decouples the host operating system from 
' the processor in a manner that is transparent to the host operating system, which has no 
awareness that it has been decoupled or recoupled to the processor 

The method disclosed herein is also advantageous in that even if the host 
operating system is decoupled from the processor with respect to same functionality 

IS normally provided by the host operating system, the host operating system remains 
coupled to the host processor for the remainder of the functionality of the host processor. 
During this period, the host operating system continues to manage much of the hardware 
functionality of the computer system, allowing the guest operating system to route a print 
request through the host operating system. 

20 An advantage of reallocating the page table of the hypervisor in the event 

of a conflict with the guest computer system is thai the reallocation of the page table 
allows the page table of the hypervisor to shadow the page table of the guest operating 
system, while at the same time mapping in the code of the hypervisor itself In this 
environment, changes to the page table of the guest operating system do not result in a 

25 conflict between the page tables of the guest operating system and the hypervisor. m 
addition, the reallocation of the page table of the hypervisor is transparent to the operation 
of the guest operating system, avoiding the possibility of creating system-level conflicts in 
the guest operating system. 

Other technical advantages of the present invention will be readily apparent 

30 to one skilled in the art from the following figures, descriptions, and claims. 
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BRIEF PBSCRIPTON Of THE DRAWINOS 

A more complete understanding of the present invention and advantages 
thereof may be acquired by referring to die following description taken in conjunction 
with the accompanying drawings, in which like reference numbers indicate like features, 
5 and wherein: 

Figure 1 is a diagram of the logical relationship of the elements of an . 
emulated computer system running in a host computer system; 

Figure 2 is a flow diagram of the method for logically coupling a 
hyperviscr of an emulation program to the processor of a computer system; 
10 Figure 3 is a diagram of the logical relationship of the elements of an 

emulated computer system in which a hypervisor is logically coupled to the processor of 
the computer system; and 

Figure 4 is a flow diagram of a method for mapping die page tables of a 
guest operating system. 

15 

DETAILED DESCRIPTION OF THE INVENTION 

The present invention provides an emulation environment that allows the 
emulation software access to the lower level hardware components of the host computer 
system. The invention involves an emulation program that includes a hypervisor that is 

20 transparent to the host operating system. The hypervisor of the emulation program 
logically disconnects or decouples the operating system from exclusive control of the host 
computer system for brief periods, during which tune the hypervisor of the emu la ti o n 
program is placed in control of me hardware of the host computer system, allowing the 
emulation program to be logically near, for brief periods, certain hardware features of the 

25 host compnter system. 

The processor state of the processor is a snapshot of all of the processor 
settings at a single point in time. These settings include both data that the processor is 
manipulating as well as the program counter, pointers, and other operational flags used by 
the processor. Because the data being manipulated by the processor and many other 

30 processor settings may change with each processor cycle, the processor state may likewise 
change with each processor cycle, and may change as often as many millions of times per 
second. 
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One subset of the processor state is the user state. Taken together, the data 
being manipulated by the processor and the processor's program counter comprise the user 
state of flic processor. The user state is so named because (he values that comprise the 
user state can be manipulated by an application-level program. The remainder of the 
5 processor settings of the processor state comprise the supervisor state or privileged state of 
the processor. The values of the supervisor state can only be modified by software mat is 
part of the operating system of the computer system. The settings of the supervisor state 
or privileged state of the processor state cannot be accessed by an application-level 
program. The separation of processor settings between a user state, which is accessible by 

10 apptication-level programs, and a supervisor state, which is not accessible by application- 
level programs, allows the operating system to remain functional even if the application 
level program crashes or causes a fatal error. 

The settings of the supervisor state of the processor generally fall into one 
of several categories. One category of the supervisor state of the processor is the 

15 processor's mode flags, which include the settings that instruct the processor to operate 
according to one of several modes to support certain computational situations, exception 
behavior, support for legacy programs, or the selective use of newer features of the 
processor. Another category of settings of the processor state arc- those settings that 
control external hardware access. Processors often support several operational settings for 

20 communication between the processor and hardware external to the processor, such as 
caches, memory, and other input and output devices. Because these operational settings, 
including the conxmnmication speed and bandwidth, for example, can only be modified by 
privileged or supervisor level code, they are considered to be part of the supervisor state of 
the processor. 

25 Another category of settings of the privileged state of the processor are the 

exception and interrupt routine pointers. When the processor encounters an exception or 
is asked for an interrupt, the processor stops execution at the current program counter 
address and begins execution at a predetermined exception routine address. The location 
of these exception routines are identified through the use of exception routine pointers. 

30 For some processors, the exception routines are located at hard-coded memory addresses. 
On most processors, however, their locations are programmable and the value of the 
locations are considered to be part of the supervisor state of the processor. 
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A set of data structure pointers make up another category of the privileged 
state of the processor. Because some data structures of the processor state are too large to 
be stored in the processor, these data structures are stored in main memory and a pointer to 
the data structure is stored at the processor. An example of this sort of large data 

5 structure is the processor's page tables. These tables define for the processor the logical- 
to-physical translation of memory addresses that are necessary for the conversion of 
virtual memory accesses to physical memory locations. Both the page table and the 
pointer to fee page table, which is stored at the processor, are considered to be part of the 
supervisor state of the processor. Another example of a data structure of the processor's 

10 supervisor state that is stored in main memory is an exception routine pointer table. 
Rather than storing the pointer for each exception routine at the processor, a single pointer 
stored at the processor can point to a table of exception routine pointers. The exception 
pointer or vector table will include a listing of address pointers to the exception handlers 
accessible by the processor. Both the exception routine pointer that is stored at the 

15 processor and the exception routine pointer table are considered part of the supervisor 

The host operating system typically establishes for the processor the 
vectors or pointers to the exception and interrupt handler routines. If, for example, the 
processor is instructed to process a set of commands mat will cause the processor to divide 

20 by zero, the processor will caD the exception handler routine that handles the divide-by- 
zero exception, m doing so, the processor may call an exception handler routine that is 
pointed to by a vector stored at the processor. Alternatively, the processor may scan the 
exception vector table for the correct exception handler for the exception condition and 
then call the exception handler using the exception vector or pointer associated with the 

25 applicable exception handler. 

When the host operating system is in logical control of the host processor, 
the host operating system defines for the host processor the exception vectors and all other 
vectors that will be needed by and are supported by the host processor. Should the 
processor encounter an exception condition or need to access another routine that is 

30 referenced by a vector, such as the page table routines and the page table vector, the 
processor executes the host operating system's exception handler. 
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Id the case of an emulated computer system, an emulation program 
provides an emulated operating environment in the host computer system. Shown in 
Figure 1 is a diagram of the logical layers of the hardware and software architecture for an 
emulated operating environment in a computer system 10. An emulation program 14 runs 
5 on a host operating system that executes on the host computer system hardware or 
processor 11. Emulation program 14 emulates a guest computer system 16, including a 
guest operating system 18. Guest application programs are able to execute on guest 
operating system 18. m the emulated operating environment of Figure 1, because of the 
operation of emulation progr a m 14, guest application 20 can run on the computer system 

10 10 even though guest application 20 is designed to run on an operating system that is 
generally mcompatible with host operating system 12 and host computer system hardware 
11. In the architecture of Figure 1, guest operating system 18 is separated from the host 
computer system hardware 1 1 across several logical and software layers, including the 
host operating system 12. This logical separation introduces latency and performance 

15 difficulties in those instances in which the guest operating system attempts to 
communicate directly with the host computer system hardware 11. 

In the example of Figure 1, host operating system 12 is in exclusive 
operating control of the host computer system hardware 11, including the processor of the 
host computer system. The host operating system will have established for the processor 

20 of the host computer system a number of tho settings of the processor state. For example, 
the host operating system 12 may have established a set of exception handler vectors, 
whether located in a vector table or in the registers of me host processor, a set of interrupt 
handlers, and a page table vector. Thus, when the processor makes exception handler 
calls, interrupt handler calls, or memory management calls, the processor settings for these 

25 calls is provided on an exclusive basis by the host operating system. Because the host 
. operating system established the settings of the supervisor or privileged state of the 
processor, the host operating system is said to be in logical control of the processor of the 
host computer system. 

According to the emulation technique of the present invention, the 

30 emulation program itself includes a hyp eraser that is able to logically disconnect or 
decouple the host operating system from exclusive control of the processor and other host 
computer syBtem hardware 11. The hypervisor of emulation program 14 accomplishes the 
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logical disconnection step by reading in and saving to a memory location the vectors and 
other address pointers that are used by the host processor. A flow diagram of the steps 
taken by the bypervisor to logically disconnect the host operating system from the 
exclusive control of the host computer system and to logically connect or couple the 
5 hypervisor of the emulation program to the host computer system is shown in Figure 2. 
When the hypervisor of the emulation program wants to assert control over at least some 
of the processor settings of the processor, the hypervisor at step 24 roads in some or all of 
the settings of the supervisor or privileged state of the processor. According to one 
embodiment of the invention, the processor reads in the address pointers from the 

10 applicable registers of the processor, including the exception vectors or the pointer to the 
exception vector table, the interrupt pointers or the pointer to the interrupt routine table, 
and the pointer to the page table. At step 26, the hypervisor saves these processor settings, 
together with an identification of their associated storage location on die host processor, to 
memory. The hypervisor next substitutes at step 28 the user-level processor state of the 

15 guest operating system and the privileged-level state of the hypervisor of the emulation 
program. As a result, the processor settings of the host processor are replaced with a 
combination of the user-level processor state of the guest operating system and the 
privileged-level state associated with the hypervisor of the emulation pr ogr am In doing 
so, the hypervisor stores in (ho appropriate registers of the processor the vectors and other 

20 address pointers to the exception handlers, interrupt routines, and page maps of the 
hypervisor of the emulation program and the guest operating system. 

Because the processor nettings mat are substituted by the hypervisor of the 
emulation program are supervisor or privileged level settings, me hypervisor of the 
emulation program has logical control of the processor for all of the substituted processor 

25 settings. In this manner, the emulated computer system is logically in control of the 
hardware functionality of the host computer system for the functionality governed by the 
substituted processor settings. A diagram of the logical relationship of the emulation 
program 14 following substitution of the processor settings is shown in Figure 3. 
Hypervisor 22 in Figure 3 is shown as being a component of emulation program 14, which 

30 is shown as having a logical committncation link to the processor and host hardware 1 1 . 

As an example of the emulation progr am 's logical control of host hardware 
II, if an exception were to occur during this period, the processor would call an exception 
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handler provided by the hypcrvieor of (he emulation program. Similarly, if the processor 
is called on to translate a virtual memory address to a physical memory address, the 
processor will access the page table associated with the guest operating system. Thus, 
many settings of the processor states have been replaced so that the processor is calling 
5 upon or accessing software or data structures provided directly by tho guest operating 
system. This allows the guest operating system to logically align itself more closely with 
the processor of the computer system, and ehminatra the latency caused by separating the 
guest operating system from the processor of the computer system across die host 
operating system. In the case of an exception, the exception handler of the hypervisor may 

10 handle the exception itself or the exception handler of the hypervisor may invoke the 
exception handler of the guest operating system, allowing the guest operating system to 
directly handle the exception without the necessity of having the exception call pass 
through the host operating system software layer. 

As shown in Figure 3, host operating system 12 is not permanently 

15 disconnected form me hardware of the host computer system. The logical control asserted 
by tho hypervisor over a set of processor settings docs not result in hypervisor 22 
assuming responsibility over all the hardware interaction in die computer system. During 
those periods when the host operating system is handling a function request relating to the 
hardware of the computer system, the host operating system must be in logical control of 

20 the computer system. To accomplish this, the host operating system must be temporarily 
logically recoup led to the hardware of the computer system. Once the host operating 
system has completed the functions requested by the emulation program, the emulation 
program can reassume its logical control over the exception and interrupt handlers 
associated with the processor setting of the emulation program. 

25 With regard to the flow diagram of Figure 2, at step 30, hypervisor 22 

returns the logical control over the processor settings to the host operating system, 
Hypervisor 22 retrieves from memory the vectors and other pointers that were saved to 
memory. These addresses are written back to the appropriate register locations, returning 
logical control over these processor settings to the host operating system. During the 

30 period that the host operating system is logically disconnected from the processor, tho 
logical disconnection of host operating system 12 is not apparent to host operating system 
12. Host operating system 12 is not aware that a set of processor settings has been 
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substituted, resulting in the transfer of logical control for some hardware functionality to 
the emulation program. When logical control is returned to host operating system 12, host 
operating system 12 is similarly not aware that logical control of a set of hardware calls 
has been returned to it 

5 Tho substitution of some of the processor settings of the processor 

supervisor states results in a performance gain by the emulation program as compared with 
the option of the handling by the emulation program of exceptions, interrupts, and memory 
management functions as filtered through tho host operating system. In those cases in 
which the emulation program operates as an application pr o g r am that resides on the host 

10 operating system, logically disconnecting tho host operating system from exclusive control 
over me functionality of the processor is a performance advantage for the emulated 
computer system. Once the host operating system has been logically decoupled from at 
least some of tho functionality of the processor, the emulation program, by substituting its 
processor settings for the processor settings of the host operating system, can operate 

15 much more closely with the host processor. Once the processor settings have been 
substituted, the emulation program can direct the processor to the emulation program's 
own set of exception vectors, interrupt routines, and page tables, thereby avoiding the 
latency problems caused when tho host operating system separates the processor from the 
emulation program. 

20 The interrupt and exception handling functions of the hypervisor of the 

present invention also permit the handling of exceptions and interrupts as expected by tho 
guest operating system. An operating system may choose to handle certain exceptions at 
the operating system level without passing these exceptions to tho application that initiated 
the exception. One example is the divide-by-zero exception, which is often handled by the 

25 operating system without being passed to the application program that initialed the 
exception. The hypervisor of the emulation program can continue to pass exceptions to 
the guest operating system without the necessity of initiating an exception handler in the 
hypervisor. Thus, as expected, when a guest application program causes the initiation of a 
divide-by-zero exception at a time when the emulation program is in logical control of (he 

30 processor with respect to the substituted processor settings, the hypervisor of the 
emulation program is able to peas the exception to the guest operating system. 
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Shown in Figure 4 is a flow diagram of a method for mapping the page 
tables of a guest operating system. At step 40, the bypcrvisor identifies a write to the page 
table of the guest operating system. At step 42, the hypervisor determines if the write to 
the page table of the guest operating system resulted in mapping conflict between the page 
5 tables of the guest operating system and the page table of the hypervisor. The page tabic 
of the hypervisor closely minors the page table of the guest operating system, with the 
principal difference being that the page table of the hypervisor maps b to its page table the 
code and data of the hypervisor. The hypervisor determines that mere is a conflict, for 
example, if mapped pages in the page table of the guest operating system overlap with the 

1 0 mapped in locations of the hypervisor in the page tables of the hypervisor. 

If the hypervisor determines that there will be no conflict caused by the 
change to the page tables of the guest operating system, then no change is necessary to the 
page tables of the hypervisor (step 44). If the hypervisor determines that a change to the 
page table of the guest operating system causes a conflict with the page table of the host 

15 computer system, the hypervisor reallocates its page table at step 46 so that the code and 
data of the hypervisor itself is moved or mapped in to another location in the page table of 
tfas hypervisor. This process of identifying a change to the page table of the guest 
operating system and, if necessary, reallocating the page table of the hypervisor in 
response, is transparent to the operation of the guest operating system. Once the page 

20 table of the hypervisor has been reallocated, if necessary, the page table of the guest 
operating system no longer conflicts with the page table of hypervisor. 

The present invention is not limited in its application to the emulation of a 
particular computer system architecture, particularly the Intel 80X86 architecture. Rather, 
the emulation technique disclosed herein is applicable any time it is desirable that a host 

25 operating system be transparently disconnected from the processor with respect to at least 
some of the processor settings of the processor. 

Although the present invention has been described in detail it should be 
understood mat various changes, substitutions, and alterations can be made thereto without 
departing from the spirit and scope of the invention as defined by the appended claims. 
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WHAT IS CLAIMED K; 

1. A method for emulating in a host computer system a guest computer 
system, the guest computer system including a guest operating system, comprising the 

5 steps of: 

establishing in the host computer system a bypcrvisor for hosting a guest 
operating system; 

establishing in the hypervisor a page table; 

monitoring the page table of the guest operating system; and 
10 reallocating the page table of the hypervisor if a change to the page table of 

the guest operating system, causes a conflict between the page table of the hypervisor and 
the page table of the guest operating system. 

2. The method for emulating in a host computer system a guest computer 
15 system, the guest computer system including a guest operating system of claim 1, wherein 

the page table of the hypervisor generally mirrors the page table of the guest operating 
system, except for the inclusion in the page table of the hypervisor of the mapping of the 
code of the hypervisor. 

20 3. The method for emulating in a host computer system a guest computer 

system, the guest computer system including a guest operating system of claim 1, wherein 
the step of monitoring the page table of the guest operating system comprises the step of 
monitoring for writes to the page table of the guest operating system. 

25 4. The method for emulating in a host computer system a guest computer 

system, the guest computer system including a guest operating system of claim 1, wherein 
the step of reallocating the page table of the hypervisor comprises the step of reallocating 
the mapping of the code of the hypervisor such that the code of the hypervisor is not 
mapped in to a memory location that overlaps with a mapped in memory location of the 

30 page table of me guest operating system. 
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5. The method for emulating in a host computer system a guest computer 
system, the guest computer system including a guest operating system of claim 1, 

wherein the page table of the hypervisor generally mirrors the page table of 
the guest operating system, except for the inclusion in me page table of the hypervisor of 
5 the mapping of the code of the hypervisor; 

wherein the step of monitoring the page table of the guest operating system 
comprises the step of monitoring for writes to the page table of the guest operating system; 
and 

wherein the step of reallocating the page table of the hypervisor comprises 
10 the step of reallocating the mapping of the code of the hypervisor such that the code of the 
hypervisor is not mapped in to a memory location that overlaps with a mapped in memory 
location of the page table of the guest operating system 



6. A method for reconciling, in an emulated computing environment, the page 
15 table of a guest operating system with the page table of a hypervisor, wherein the 
hypervisor is hosting the guest operating system on the host computer system, comprising 
the steps: 

establishing the page table of the hypervisor such that the page table of die 
hypervisor largely mirrors the page table of the guest operating system, with the addition 
20 that the page table of the hypervisor includes an allocation of memory space for the code 
of the hypervisor, 

monitoring the page table of the guest operating system fox changes to the 
page table of the guest operating system; 

if a change to the page table of the guest operating system causes a conflict 
25 between the page table of the hypervisor and the page table of the guest operating system,' 
reallocating the page table of the guest operating system so that there is not a conflict 
between the page table of the hypervisor and the page table of the guest operating system. 
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7. The method for reconciling, in an emulated computing environment, the 
page table of a guest operating system with the page table of a hypervkor of claim 6, 
wherein the step of reallocating the page tabic of the guest operating system comprises the 
step of reallocating tho page mappings of the code of the hypervisor such that the page 

5 mappings of tho code of the hypervisor do not overlap with any mapped in pages in the 
guest operating system. 

8. The method tor reconciling, in an emulated computing environment, the 
page tablo of a guest operating system with the page table of a hypervisor of claim 7, 

10 wherein the step of monitoring the page table of the guest operating system comprises the 
step of determining when there has been a write to the page table of the guest operating 
system 

9. A method for emulating in a host computer system a guest computer 
IS system, the host computer system including a processor and a host operating system, 

comprising the steps o£ 

running an emulator program on the host system that emulates the 
operation of a guest operating system; 

reading in from the processor, of the computer system a processor setting 
20 associated with the host operating system; 

writing the processor setting to memory; 

writing to the processor a guest processor setting associated with the 
emulator program; 

wherein the host operating system is logically decoupled from die 
25 processor for the processor function related to the guest processor setting associated with 
the emulator program. 
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10. The method for emulating in a host computer system a guest computer 
system of claim 9, 

wherein the processor setting associated with the emulator program is an 
exception vector, and 

5 further comprising the step of calling the exception handler pointed to by 

the exception vector. 

11. The method for emulating in 8 host computer system a guest computer 
system of claim 9, further comprising the steps of, 

10 reading in from memory the processor setting associated with the host 

operating system; 

writing to the processor the processor setting associated with the host 
operating system, wherein the host operating system is logically coupled to the processor 
for the function related to the processor setting associated with the host operating system. 

15 

12. The method for emu I wring in a host computer system a guest computer 
system of claim 9, further comprising the steps of: 

temporarily logically recoup ling die host operating system to the processor 
for the purpose of performing a function requested by die emulator program; and 
20 logically recoup ling the emulator program to the processor for the function 

related to the processor setting associated with the emulator program following the 
completion by the host operating system of die function requested by the emulator 
program. 
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system of claim 9, wherein the emulator program operates as an application program on 
the host operating system. 
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14. The method for *r rm 1"*i" fl in a host computer system o guest computer 
system of claim 9, 

wherein the processor setting associated with the emulator program is an 
interrupt routine pointer, and 
5 further comprising the step of calling the interrupt routine pointed to by the 

interrupt routine pointer. 



15. The method for emulating in a host computer system a guest computer 
system of claim 9, 

10 wherein the processor setting associated with the emulator program is a 

pointer to an exception vector table; and 

further comprising the step of accessing the exception vector table using the 
processor setting associated with the emulator program. 



15 16. The method for emulating in a host computer system a guest computer 

system of claim 9, 

wherein the processor setting associated with the emulator program is a 
pointer to a page table associated with the guest computer system; and 

further comprising the step of accessing the page table of the guest 
20 computer system using the processor setting associated with the emulator program. 
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17. A method for logically decoupling a host operating system of a computer 
system from the processor of the computer system, comprising the steps of: 

running as an application program on the host computer system as emulator 
program that emulates the operation of a guest operating system, the guest operating 
5 system having a set of functionality associated with too supervisor state of {he processor of 
the computer system; 

replacing in the processor as part of a first replacement step a processor 
setting associated with the functionality of the guest operating system and the supervisor 
state of the processor such that the host operating system is logically decoupled from the 
10 processor with respect to the processor operations associated with the replaced processor 

replacing in the processor as part of a second replacement step a processor 
setting associated with the functionality of the host operating system such that the host 
operating system is logically recoupled to the host operating system with respect to the 
1 S processor operations associated with the replaced processor setting. 

18. The method for logically decoupling a host operating system of a computer 
system from the processor of the computer system of claim 17, wherein the processor 
Betting associated with the functionality of the guest operating system is a pointer to an 

20 exception handler provided by the guest operating system. 

1 9. The method for logically decorrphng a host operating system of a computer 
system from the processor of the computer system of claim 1 7, wherein the processor 
setting associated with the functionality of the guest operating system is a pointer to a page 

25 tabic of the guest operating system. 
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20. The method fox logically decoupling a host operating system of a computer 
system from the processor of the computer system of claim 17, further comprising the 
steps of. 

temporarily logically recouplrag the host operating system to the processor 
5 for the purpose of performing a function requested by the emulator program; and 

logically recoup ling the emulator program to the processor for the 
processor settings associated with the guest operating system following the completion by 
the host operating system of the function requested by me emulator program. 

10 21 The method for logically decoupling a host operating system of a computer 

system from the processor of the computer system of claim 17, wherein the first 
replacement step comprises the steps of, 

reading in from an identifiable register of the processor a processor setting 
associated with the host operating system; and 

1 5 writing the processor setting read in from memory to memory. 

22. The method for logically decoupling a host operating system of a computer 
system from the processor of the computer system of claim 21, wherein the second 
replacement Btep comprises the steps of, 

20 reading in from memory the processor setting associated with the host 

operating system; and 

writing foe processor setting to foe identifiable register of the processor. 

23. The method for logically decoupling a host operating system of a computer 
25 system from the processor of the computer system of claim 21, wherein the memory is 

RAM memory. 

24. The method for logically decoupling a host operating system of a computer 
system from the processor of the computer system of claim 17, wherein me processor 

30 setting associated with the functionality of the guest operating system is a pointer to an 
exception handler provided by foe guest operating system. 
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25. A method for rerouting calb by a processor of a computer system to a guest 
operating system being emulated on s host operating system of the computer system, 
comprising the steps ofi 

reading in a first set of processor settings from the processor, the processor 
settings being associated with functionality provided by the host operating system; 
storing the first processor settings in memory, 

writing in a second set of replacement processor settings to the processor, 
the replacement set of processor settings associated with the functionality provided by the 
guest operating system, wherein with respect to the functionality associated with the 
replacement set of processor settings, the host operating system is logically decoupled 
from the processor and the guest operating system is logically coupled to the processor. 

26. The method for rerouting calls by a processor of a computer system to a 
guest operating system being emulated on a host operating system of the computer system 

15 of claim 25, further comprising the steps of, 

reading in the first set of processor settings stored in memory; and 
writing the first set of processor settings to the processor, wherein with 

respect to functionality associated with the first set of processor settings, the host 

operating system is logically coupled to the processor. 

20 

27. A method for logically decoupling a host operating system from a 
processor of a computer system, comprising the steps of: 

saving the contents of a set of registers on the processor to memory, the set 
of registers storing at least a part of the processor settings of the processor; and 
25 writing to the set of registers a replacement set of processor settings 

associated with functionality provided by a guest operating system that resides as an 
application program on the host operating system. 
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28. The method for logically decoupling a host operating system from a 
processor of o computer system of claim 20, wherein the replacement set of registers 
includes pointers to exception handler routines provided by the host operating system. 

5 29. The method for logically decoupling a host operating -system from a 

processor of a computer system of claim 27, wherein the replacement set of registers 
includes pointere to interrupt handler routines provided by the host operating system. 

30. The method for logically decoupling a host operating system from a 
10 processor of a computer system of claim 27, wherein the replacement set of registers 
includes a page table associated with the host operating system- 
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